package com.zhiyou100.review.day007.sort;

import java.util.Arrays;

/**
 * @packageName: InsertionSort
 * @className: com.zhiyou100.review.day007.sort
 * @Description: TODO 插入排序
 * @author: yang
 * @date: 6/16/20
 */
public class InsertionSort {
    public static void main(String[] args) {
        int[] ints = {6, 2, 4, 7, 3, 1, 5, 8, 2, 0};
        System.out.println(Arrays.toString(ints));
    }

    /**
     * @Description: TODO 插入排序
     * @name: myInsertionSorted
     * @param: [array]
     * @return: int[]
     * @date: 6/16/20 20:18
     * @author: yang
     */
    public static int[] myInsertionSorted(int[] array) {
        int i;
        // i 记录 一共循环的次数
        int j;
        // j 记录 比较的次数
        for (i = 1; i < array.length; i++) {
            int temp = array[i];
            // 当前元素 是 array[i]
            // 使用 temp 记录 array[i]
            for (j = i - 1; j >= 0; j--) {
                // array[j] 是当前元素
                if (array[j] > temp) {
                    // 如果 array[j] 前面的元素 > temp , array[j] 向后移动一位
                    array[j + 1] = array[j];
                } else {
                    // 如果 当前元素 比 temp 小，跳出比较
                    break;
                }
            }
            array[j + 1] = temp;
            // 把 temp 放在 j+1 的位置
        }
        return array;
    }
}
